home *** CD-ROM | disk | FTP | other *** search
/ Mac Easy 2010 May / Mac Life Ubuntu.iso / casper / filesystem.squashfs / usr / share / pyshared / checkbox / registries / command.py next >
Encoding:
Python Source  |  2009-04-27  |  1.7 KB  |  58 lines

  1. #
  2. # This file is part of Checkbox.
  3. #
  4. # Copyright 2008 Canonical Ltd.
  5. #
  6. # Checkbox is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU General Public License as published by
  8. # the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # Checkbox is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14. # GNU General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU General Public License
  17. # along with Checkbox.  If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. import logging
  20.  
  21. from checkbox.lib.process import Process
  22.  
  23. from checkbox.frontend import frontend
  24. from checkbox.properties import String
  25. from checkbox.registry import Registry
  26.  
  27.  
  28. class CommandRegistry(Registry):
  29.     """Base registry for running commands.
  30.  
  31.     The default behavior is to return the output of the command.
  32.  
  33.     Subclasses should define a command parameter.
  34.     """
  35.  
  36.     command = String()
  37.  
  38.     def __init__(self, command=None):
  39.         super(CommandRegistry, self).__init__()
  40.         if command is not None:
  41.             self.command = command
  42.  
  43.     @frontend("get_registry")
  44.     def __str__(self):
  45.         logging.info("Running command: %s", self.command)
  46.         process = Process(self.command)
  47.         while process.read():
  48.             pass
  49.  
  50.         if process.errdata:
  51.             logging.error("Failed to run command: %s", process.errdata.strip())
  52.         return process.outdata
  53.  
  54.     def items(self):
  55.         # Force running the command
  56.         item = str(self)
  57.         return []
  58.